package com.hong.spring.h2;

import org.h2.tools.Server;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import java.sql.SQLException;

/**
 * @ClassName: H2DBServerStartListener
 * @Description: 用于启动H2数据库服务的监听器，在应用系统初始化时就启动H2数据库的服务
 * @author: 孤傲苍狼
 * @date: 2014-12-20 下午11:43:39
 */
public class H2DBServerStartListener implements ServletContextListener {
    Logger logger = LoggerFactory.getLogger(H2DBServerStartListener.class);
    //H2数据库服务器启动实例
    private Server server;

    /*
     * Web应用初始化时启动H2数据库
     */
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        try {
            System.out.println("正在启动h2数据库...");
            //使用org.h2.tools.Server这个类创建一个H2数据库的服务并启动服务，由于没有指定任何参数，那么H2数据库启动时默认占用的端口就是8082
            server = Server.createTcpServer("-tcpPassword", "test123").start();
            System.out.println("h2数据库启动成功...");
        } catch (SQLException e) {
            e.printStackTrace();
            logger.error("启动h2数据库出错：", e);
            throw new RuntimeException(e);
        }
    }

    /*
     * Web应用销毁时停止H2数据库
     */
    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        if (this.server != null) {
            // 停止H2数据库
            this.server.stop();
            this.server = null;
        }
    }
}